Common Iteration Errors
Infinite Loop Errors
It is important to consider how a loop will end. All loops have a condition expression that must evaluate to false for the loop to end. If the condition never evaluates to false, than an infinite loop will result and the program will never end, and may crash by filling up the program's memory or causing other types of overflow errors. Often, it appears as if the program is doing nothing, when it is really stuck in a loop of repeating the same actions over and over.
Here's an example of an infinite loop:
sum = 0; count = 10; while ( count > 0 ) sum = sum + 10; end
To fix an infinite loop, add code that changes (updates) something in the conditional expression so that eventually it evaluates to false.
count = 10; while ( count >= 0 ) sum = sum + 10; count = count - 1; end
What would happen if the additional line was count = count - 1
Off-by-one Errors
Another important consideration when implementing iterative code, is the number of times that the loop must execute to solve the problem. It is a very common mistake to program a loop that executes one too many times or one too few times. This type of programming error is a semantic error and as such can not be caught by the programming environment's syntax checker. It is the programmer's responsibility to ensure that the body of each loop repeats the correct number of times for all possible cases of entering the loop.
Here's an example of a loop that has an off-by-one error if we wish it to execute 10 times.
sum = 0; count = 10; while ( count >= 0 ) sum = sum + 10; count = count - 1; end
One way to determine if a loop executes the correct number of times is to reduce the count number and trace the execution manually.
sum = 0; count = 1; while ( count >= 0 ) sum = sum + 1; count = count - 1; end
If you don't find the problem this way, then use the Debugging tool to trace the actual code.